博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHPCMS分页原理
阅读量:5908 次
发布时间:2019-06-19

本文共 3839 字,大约阅读时间需要 12 分钟。

调用很方便,使用listinfo方法,如果小于1页不会返回分页字符串

$page = $_GET['page'] ? intval($_GET['page']) : '1';$products = $this->product_db->listinfo($where,'', $page, 10);$pages = $this->product_db->pages;

listinfo方法

/** * 查询多条数据并分页 * @param $where * @param $order * @param $page * @param $pagesize * @return unknown_type */final public function listinfo($where = '', $order = '', $page = 1, $pagesize = 20, $key='', $setpages = 10,$urlrule = '',$array = array(), $data = '*') {    $where = to_sqls($where);    $this->number = $this->count($where); // 获取总数    $page = max(intval($page), 1);        // 当前页    $offset = $pagesize*($page-1);        // 位移,每页数据数目    $this->pages = pages($this->number, $page, $pagesize, $urlrule, $array, $setpages); // 处理分页    $array = array();    if ($this->number > 0) {        return $this->select($where, $data, "$offset, $pagesize", $order, '', $key);    } else {        return array();    }}

这个方法返回的数据跟select方法返回一致,不过它处理了pages属性。

to_sqls方法

/** * 生成sql语句,如果传入$in_cloumn 生成格式为 IN('a', 'b', 'c') * @param $data 条件数组或者字符串 * @param $front 连接符 * @param $in_column 字段名称 * @return string */function to_sqls($data, $front = ' AND ', $in_column = false) {    if($in_column && is_array($data)) {        $ids = '\''.implode('\',\'', $data).'\'';        $sql = "$in_column IN ($ids)";        return $sql;    } else {        if ($front == '') {            $front = ' AND ';        }        if(is_array($data) && count($data) > 0) {            $sql = '';            foreach ($data as $key => $val) {                $sql .= $sql ? " $front `$key` = '$val' " : " `$key` = '$val' ";            }            return $sql;        } else {            return $data;        }    }}

pages方法

/** * 分页函数 * * @param $num 信息总数 * @param $curr_page 当前分页 * @param $perpage 每页显示数 * @param $urlrule URL规则 * @param $array 需要传递的数组,用于增加额外的方法 * @return 分页 */function pages($num, $curr_page, $perpage = 20, $urlrule = '', $array = array(),$setpages = 10) {    if(defined('URLRULE') && $urlrule == '') {        $urlrule = URLRULE;        $array = $GLOBALS['URL_ARRAY'];    } elseif($urlrule == '') {        $urlrule = url_par('page={$page}');    }    $multipage = '';    if($num > $perpage) {        $page = $setpages+1;        $offset = ceil($setpages/2-1);        $pages = ceil($num / $perpage);        if (defined('IN_ADMIN') && !defined('PAGES')) define('PAGES', $pages);        $from = $curr_page - $offset;        $to = $curr_page + $offset;        $more = 0;        if($page >= $pages) {            $from = 2;            $to = $pages-1;        } else {            if($from <= 1) {                $to = $page-1;                $from = 2;            }  elseif($to >= $pages) {                $from = $pages-($page-2);                $to = $pages-1;            }            $more = 1;        }        $multipage .= ''.$num.L('page_item').'';        if($curr_page>0) {            $multipage .= ' '.L('previous').'';            if($curr_page==1) {                $multipage .= ' 1';            } elseif($curr_page>6 && $more) {                $multipage .= ' 1..';            } else {                $multipage .= ' 1';            }        }        for($i = $from; $i <= $to; $i++) {            if($i != $curr_page) {                $multipage .= ' '.$i.'';            } else {                $multipage .= ' '.$i.'';            }        }        if($curr_page<$pages) {            if($curr_page<$pages-5 && $more) {                $multipage .= ' ..'.$pages.' '.L('next').'';            } else {                $multipage .= ' '.$pages.' '.L('next').'';            }        } elseif($curr_page==$pages) {            $multipage .= ' '.$pages.' '.L('next').'';        } else {            $multipage .= ' '.$pages.' '.L('next').'';        }    }    return $multipage;}

处理拼接成分页html

本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/5829991.html,如需转载请自行联系原作者

你可能感兴趣的文章
Linux 终于足够好,可以取代 Windows 了吗?
查看>>
《从LinkedIn走向成功》一第1章 从全新角度审视社交媒体—LinkedIn动力公式
查看>>
Apache Kylin 首批入驻微软 Azure 镜像市场
查看>>
springcloud(九):配置中心和消息总线(配置中心终结版)
查看>>
《Java数字图像处理:编程技巧与应用实践》——1.2 Java 2D API
查看>>
《Power Designer系统分析与建模实战》——2.3 餐饮在线点评系统的需求模型
查看>>
开源的强大和超凡毋庸置疑,可以用来做设计吗?
查看>>
《PaaS程序设计》一1.5 管理平台与产品化平台
查看>>
Google DeepMind 要逆天,能为 AI 赋予记忆不断学习
查看>>
《软件定义数据中心:Windows Server SDDC技术与实践》一第1章 微软数据中心与SDDC漫谈...
查看>>
《操作系统真象还原》——1.2 我们需要哪些编译器
查看>>
《机器学习与数据科学(基于R的统计学习方法)》——2.6 读取Excel文件
查看>>
《软件测试高薪之路:UFT/QTP 面试权威指南》目录—导读
查看>>
《位置大数据隐私管理》—— 第2章 典型攻击模型和隐私保护模型 2.1 位置连接攻击...
查看>>
《响应式Web设计实践》一第2章 流动布局
查看>>
《 短文本数据理解》——导读
查看>>
《领域驱动设计:软件核心复杂性应对之道(修订版)》—第2章 2.5节解释性模型...
查看>>
AWS S3误操作,官方故障回顾及专家深度思考
查看>>
《Spark 官方文档》Spark编程指南
查看>>
《正则表达式经典实例(第2版)》——2.11 捕获和命名匹配子串
查看>>